package com.bright.hander;

import com.bright.utils.RedisUtils;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@Component
public class LoginInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//        SURL = "/admin/login";
        String url = request.getRequestURL().toString();

        if (url.equals("/login")){
            return true;
        }

        //2.拿到请求头里面的token（如果是第一次登录，那么是没有请求头的）
        String token = request.getHeader("u-token");
        if (token==null)
        {
//            response.setContentType("application/json; charset=utf-8");
            //2.1 拦截请求并返回信息给前台 （前台后置拦截器就是根据这里面返回的json数据，来判读并跳转到登录界面）
            response.getWriter().print("{\"success\":false,\"msg\":\"NoUser\"}");
            return false;
        }
        //3、如果有token，那么就根据这个token从redis查询登录用户信息，如果redis里面还没过期，那么就正常放行，没有就进行拦截，并返回信息，叫他重新登录
        String tokenuser = RedisUtils.INSTANCE.get("token");
        System.out.println(tokenuser);
        if (tokenuser==null){
//            response.setContentType("application/json; charset=utf-8");
            response.getWriter().print("{\"success\":false,\"msg\":\"NoUser\"}");
            return false;
        }

        //4.如果没有过期，那么就重新将token和登录用户信息存到redis
        RedisUtils.INSTANCE.set(token,tokenuser,60*30);
        return true;

    }
}
